package com.MapDemo.Text;

/*
* 统计字符串中每个字符出现的次数
思路
1、键盘录入字符串
2、创建HashMap集合，键是Character，值是Integer
3、遍历字符串，得到每个字符
4、拿得到的每个字符作为键到HashMap集合中去找对应的值，看起返回值
    如果返回值是null：说明该字符在HashMap集合中不存在，就把该字符作为键，1作为值存储
    如果返回值不是null：说明该字符在HashMap集合中存在，把值+1，然后重新存储改字符和对应的值
5、遍历HashMap，得到键和值。按照要求进行拼接
* 6、输出结果
* */

import java.util.HashMap;
import java.util.Scanner;
import java.util.Set;

public class HashMapDemo_统计字符串中的每个字符出现的次数 {
    public static void main(String[] args) {
        //键盘录入字符串
        Scanner sc = new Scanner(System.in);
        System.out.println("请输入一个字符串：");
        String line = sc.nextLine();

        //创建HashMap集合，键是Character，值是Integer
        HashMap<Character, Integer> hm = new HashMap<Character, Integer>();

        //遍历字符串，得到每个字符
        for (int i = 0; i < line.length(); i++) {
            char key = line.charAt(i);
            //拿得到的每个字符作为键到HashMap集合中去找对应的值，看起返回值
            Integer value = hm.get(key);

            if (value == null) {
                //如果返回值是null：说明该字符在HashMap集合中不存在，就把该字符作为键，1作为值存储
                hm.put(key, 1);
            } else {
                //如果返回值不是null：说明该字符在HashMap集合中存在，把值+1，然后重新存储改字符和对应的值
                value++;
                hm.put(key, value);
            }
        }

        //遍历HashMap，得到键和值。按照要求进行拼接
        StringBuilder sb = new StringBuilder();

        Set<Character> keyset = hm.keySet();
        for (Character key : keyset) {
            Integer value = hm.get(key);
            sb.append(key).append("(").append(value).append(")");
        }

        String result = sb.toString();

        System.out.println(result);
    }
}
